<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <title>珠峰架构师成长计划</title>
    <link rel="stylesheet" type="text/css" href="../static/css/main.css">
</head>
<body>
<div class="nav">
    <div class="logo">
        
            珠峰架构师成长计划
        
    </div>
<ul><li><a href="../index.html">0.Async</a></li><li><a href="../html/0.editor.html">0.editor</a></li><li><a href="../html/0.module.html">0.module</a></li><li><a href="../html/1.ES2015.html">1.ES2015</a></li><li><a href="../html/2.Promise.html">2.Promise</a></li><li><a href="../html/3.Node.html">3.Node</a></li><li><a href="../html/4.NodeInstall.html">4.NodeInstall</a></li><li><a href="../html/5.REPL.html">5.REPL</a></li><li><a href="../html/6.NodeCore.html">6.NodeCore</a></li><li><a href="../html/7.module&NPM.html">7.module&NPM</a></li><li><a href="../html/8.Encoding.html">8.Encoding</a></li><li><a href="../html/9.Buffer.html">9.Buffer</a></li><li><a href="../html/10.fs.html">10.fs</a></li><li><a href="../html/11.Stream-1.html">11.Stream-1</a></li><li><a href="../html/11.Stream-2.html">11.Stream-2</a></li><li><a href="../html/11.Stream-3.html">11.Stream-3</a></li><li><a href="../html/11.Stream-4.html">11.Stream-4</a></li><li><a href="../html/12-Network-2.html">12-Network-2</a></li><li><a href="../html/12.NetWork-3.html">12.NetWork-3</a></li><li><a href="../html/12.Network-1.html">12.Network-1</a></li><li><a href="../html/13.tcp.html">13.tcp</a></li><li><a href="../html/14.http-1.html">14.http-1</a></li><li><a href="../html/14.http-2.html">14.http-2</a></li><li><a href="../html/15.compress.html">15.compress</a></li><li><a href="../html/16.crypto.html">16.crypto</a></li><li><a href="../html/17.process.html">17.process</a></li><li><a href="../html/18.yargs.html">18.yargs</a></li><li><a href="../html/19.cache.html">19.cache</a></li><li><a href="../html/20.action.html">20.action</a></li><li><a href="../html/21.https.html">21.https</a></li><li><a href="../html/22.cookie.html">22.cookie</a></li><li><a href="../html/23.session.html">23.session</a></li><li><a href="../html/24.express-1.html">24.express-1</a></li><li><a href="../html/24.express-2.html">24.express-2</a></li><li><a href="../html/24.express-3.html">24.express-3</a></li><li><a href="../html/24.express-4.html">24.express-4</a></li><li><a href="../html/25.koa-1.html">25.koa-1</a></li><li><a href="../html/26.webpack-1-basic.html">26.webpack-1-basic</a></li><li><a href="../html/26.webpack-2-optimize.html">26.webpack-2-optimize</a></li><li><a href="../html/26.webpack-3.tapable.html">26.webpack-3.tapable</a></li><li><a href="../html/26.webpack-4-AST.html">26.webpack-4-AST</a></li><li><a href="../html/26.webpack-5-source.html">26.webpack-5-source</a></li><li><a href="../html/26.webpack-6-loader.html">26.webpack-6-loader</a></li><li><a href="../html/26.webpack-7-plugin.html">26.webpack-7-plugin</a></li><li><a href="../html/26.webpack-8-hand.html">26.webpack-8-hand</a></li><li><a href="../html/27.react-1.html">27.react-1</a></li><li><a href="../html/27.react-2.html">27.react-2</a></li><li><a href="../html/27.react-3.html">27.react-3</a></li><li><a href="../html/27.react-4-immutable.html">27.react-4-immutable</a></li><li><a href="../html/27.react-5-react-dom-diff.html">27.react-5-react-dom-diff</a></li><li><a href="../html/27.react-6.html">27.react-6</a></li><li><a href="../html/28.react-mobx.html">28.react-mobx</a></li><li><a href="../html/28.redux-0.html">28.redux-0</a></li><li><a href="../html/28.redux-1.html">28.redux-1</a></li><li><a href="../html/28.redux-2-中间件.html">28.redux-2-中间件</a></li><li><a href="../html/28.redux-3-saga.html">28.redux-3-saga</a></li><li><a href="../html/28.redux-jwt-back.html">28.redux-jwt-back</a></li><li><a href="../html/28.redux-jwt-front.html">28.redux-jwt-front</a></li><li><a href="../html/29.mongodb-1.html">29.mongodb-1</a></li><li><a href="../html/29.mongodb-2.html">29.mongodb-2</a></li><li><a href="../html/29.mongodb-3.html">29.mongodb-3</a></li><li><a href="../html/29.mongodb-4.html">29.mongodb-4</a></li><li><a href="../html/29.mongodb-5.html">29.mongodb-5</a></li><li><a href="../html/29.mongodb-6.html">29.mongodb-6</a></li><li><a href="../html/30.cms-1-mysql.html">30.cms-1-mysql</a></li><li><a href="../html/30.cms-2-mysql.html">30.cms-2-mysql</a></li><li><a href="../html/30.cms-3-mysql.html">30.cms-3-mysql</a></li><li><a href="../html/30.cms-4-egg.html">30.cms-4-egg</a></li><li><a href="../html/30.cms-5-api.html">30.cms-5-api</a></li><li><a href="../html/30.cms-6-roadhog.html">30.cms-6-roadhog</a></li><li><a href="../html/30.cms-7-umi.html">30.cms-7-umi</a></li><li><a href="../html/30.cms-8-dva.html">30.cms-8-dva</a></li><li><a href="../html/30.cms-9-dva.html">30.cms-9-dva</a></li><li><a href="../html/30.cms-10-front.html">30.cms-10-front</a></li><li><a href="../html/30.cms-11-deploy.html">30.cms-11-deploy</a></li><li><a href="../html/33.redis.html">33.redis</a></li><li><a href="../html/34.unittest.html">34.unittest</a></li><li><a href="../html/35.jwt.html">35.jwt</a></li><li><a href="../html/36.websocket-1.html">36.websocket-1</a></li><li><a href="../html/36.websocket-2.html">36.websocket-2</a></li><li><a href="../html/38.chat-api-1.html">38.chat-api-1</a></li><li><a href="../html/38.chat-api-2.html">38.chat-api-2</a></li><li><a href="../html/38.chat-3.html">38.chat-3</a></li><li><a href="../html/38.chat-api-3.html">38.chat-api-3</a></li><li><a href="../html/38.chat.html">38.chat</a></li><li><a href="../html/38.chat2.html">38.chat2</a></li><li><a href="../html/38.chat2.html">38.chat2</a></li><li><a href="../html/39.crawl-0.html">39.crawl-0</a></li><li><a href="../html/39.crawl-1.html">39.crawl-1</a></li><li><a href="../html/39.crawl-2.html">39.crawl-2</a></li><li><a href="../html/40.deploy.html">40.deploy</a></li><li><a href="../html/41.safe.html">41.safe</a></li><li><a href="../html/42.test.html">42.test</a></li><li><a href="../html/43.nginx.html">43.nginx</a></li><li><a href="../html/44.enzyme.html">44.enzyme</a></li><li><a href="../html/45.docker.html">45.docker</a></li><li><a href="../html/46.elastic.html">46.elastic</a></li><li><a href="../html/47.oauth.html">47.oauth</a></li><li><a href="../html/48.wxpay.html">48.wxpay</a></li><li><a href="../html/49.nunjucks.html">49.nunjucks</a></li><li><a href="../html/50.ketang.html">50.ketang</a></li><li><a href="../html/index.html">index</a></li><li><a href="../html/51.typescript.html">51.typescript</a></li><li><a href="../html/52.UML.html">52.UML</a></li><li><a href="../html/53.design.html">53.design</a></li><li><a href="../html/index.html">index</a></li><li><a href="../html/54.linux.html">54.linux</a></li><li><a href="../html/55.yaml.html">55.yaml</a></li><li><a href="../html/50.ketang2.html">50.ketang2</a></li><li><a href="../html/56.ts.html">56.ts</a></li><li><a href="../html/57.ts_react.html">57.ts_react</a></li><li><a href="../html/58.react-ssr.html">58.react-ssr</a></li><li class="active"><a href="../html/59.react-ssr.html">59.react-ssr</a></li></ul></div>


<div class="warpper">

    <div class="page-toc">
        <ul><li><a href="#t01. 什么是服务器端渲染">1. 什么是服务器端渲染</a></li><li><a href="#t12. 客户端渲染">2. 客户端渲染</a></li><li><a href="#t23. 服务器端渲染">3. 服务器端渲染</a></li><li><a href="#t34. 优化启动流程">4. 优化启动流程</a></li><li><a href="#t45. 计数器组件">5. 计数器组件</a></li><li><a href="#t57. 使用路由">7. 使用路由</a></li><li><a href="#t68. 跳转路由">8. 跳转路由</a></li><li><a href="#t79. redux计数器">9. redux计数器</a></li><li><a href="#t811. 客户端异步加载数据">11. 客户端异步加载数据</a></li><li><a href="#t912. 服务器端路由">12. 服务器端路由</a></li><li><a href="#t1013.多级路由">13.多级路由</a></li><li><a href="#t1114.后台获取数据">14.后台获取数据</a></li><li><a href="#t1215. Node代理服务器">15. Node代理服务器</a></li><li><a href="#t1316. 抽取App.js">16. 抽取App.js</a></li><li><a href="#t1417. 实现头部根据登录状态显示导航">17. 实现头部根据登录状态显示导航</a></li><li><a href="#t1518. 实现登录功能">18. 实现登录功能</a></li><li><a href="#t1619. 退出功能">19. 退出功能</a></li><li><a href="#t1720. 加载用户信息">20. 加载用户信息</a></li><li><a href="#t1821. 404">21. 404</a></li><li><a href="#t1922. 301">22. 301</a></li><li><a href="#t2023. promise.all">23. promise.all</a></li><li><a href="#t2124. 使用CSS">24. 使用CSS</a></li><li><a href="#t2226.withStyles">26.withStyles</a></li></ul>
    </div>
    
    <div class="content markdown-body">
        <h2 id="t01. &#x4EC0;&#x4E48;&#x662F;&#x670D;&#x52A1;&#x5668;&#x7AEF;&#x6E32;&#x67D3;">1. &#x4EC0;&#x4E48;&#x662F;&#x670D;&#x52A1;&#x5668;&#x7AEF;&#x6E32;&#x67D3; <a href="#t01. &#x4EC0;&#x4E48;&#x662F;&#x670D;&#x52A1;&#x5668;&#x7AEF;&#x6E32;&#x67D3;"> # </a></h2>
<ul>
<li><a href="https://gitee.com/zhufengpeixun/zfssr/commit/e3edb4976fcdd5ebfb6ac23afcd4d7878b0c3275">1. &#x4EC0;&#x4E48;&#x662F;&#x670D;&#x52A1;&#x5668;&#x7AEF;&#x6E32;&#x67D3;</a><h2 id="t12. &#x5BA2;&#x6237;&#x7AEF;&#x6E32;&#x67D3;">2. &#x5BA2;&#x6237;&#x7AEF;&#x6E32;&#x67D3; <a href="#t12. &#x5BA2;&#x6237;&#x7AEF;&#x6E32;&#x67D3;"> # </a></h2>
</li>
<li><a href="https://gitee.com/zhufengpeixun/zfssr/commit/ae58fea42ac03267e8978b9a16ee76fd08164bab">2. &#x5BA2;&#x6237;&#x7AEF;&#x6E32;&#x67D3;</a><h2 id="t23. &#x670D;&#x52A1;&#x5668;&#x7AEF;&#x6E32;&#x67D3;">3. &#x670D;&#x52A1;&#x5668;&#x7AEF;&#x6E32;&#x67D3; <a href="#t23. &#x670D;&#x52A1;&#x5668;&#x7AEF;&#x6E32;&#x67D3;"> # </a></h2>
</li>
<li><a href="https://gitee.com/zhufengpeixun/zfssr/commit/83da000a7db49613ac54a43b7e65245d6947668e">3. &#x670D;&#x52A1;&#x5668;&#x7AEF;&#x6E32;&#x67D3;</a><h2 id="t34. &#x4F18;&#x5316;&#x542F;&#x52A8;&#x6D41;&#x7A0B;">4. &#x4F18;&#x5316;&#x542F;&#x52A8;&#x6D41;&#x7A0B; <a href="#t34. &#x4F18;&#x5316;&#x542F;&#x52A8;&#x6D41;&#x7A0B;"> # </a></h2>
</li>
<li><a href="https://gitee.com/zhufengpeixun/zfssr/commit/f7691dbd398474c65200fc0e73247038439e5ae8">4. &#x4F18;&#x5316;&#x542F;&#x52A8;&#x6D41;&#x7A0B;</a><h2 id="t45. &#x8BA1;&#x6570;&#x5668;&#x7EC4;&#x4EF6;">5. &#x8BA1;&#x6570;&#x5668;&#x7EC4;&#x4EF6; <a href="#t45. &#x8BA1;&#x6570;&#x5668;&#x7EC4;&#x4EF6;"> # </a></h2>
</li>
<li><a href="https://gitee.com/zhufengpeixun/zfssr/commit/5f8fa9d89f2a60cc7ce61eabec92b4553bde2e8d">5. &#x8BA1;&#x6570;&#x5668;&#x7EC4;&#x4EF6;</a><h2 id="t57. &#x4F7F;&#x7528;&#x8DEF;&#x7531;">7. &#x4F7F;&#x7528;&#x8DEF;&#x7531; <a href="#t57. &#x4F7F;&#x7528;&#x8DEF;&#x7531;"> # </a></h2>
</li>
<li><a href="https://gitee.com/zhufengpeixun/zfssr/commit/145209a0b25621eed5bb9c012cafd8af67649212">7. &#x4F7F;&#x7528;&#x8DEF;&#x7531;</a><h2 id="t68. &#x8DF3;&#x8F6C;&#x8DEF;&#x7531;">8. &#x8DF3;&#x8F6C;&#x8DEF;&#x7531; <a href="#t68. &#x8DF3;&#x8F6C;&#x8DEF;&#x7531;"> # </a></h2>
</li>
<li><a href="https://gitee.com/zhufengpeixun/zfssr/commit/05745228589fd1a7f33d32f798c9c0da8ec48289">8. &#x8DF3;&#x8F6C;&#x8DEF;&#x7531;</a><h2 id="t79. redux&#x8BA1;&#x6570;&#x5668;">9. redux&#x8BA1;&#x6570;&#x5668; <a href="#t79. redux&#x8BA1;&#x6570;&#x5668;"> # </a></h2>
</li>
<li><a href="https://gitee.com/zhufengpeixun/zfssr/commit/321f0a4ef842483850ce034dc11fc89a2e66d1d3">9. redux&#x8BA1;&#x6570;&#x5668;</a><h2 id="t811. &#x5BA2;&#x6237;&#x7AEF;&#x5F02;&#x6B65;&#x52A0;&#x8F7D;&#x6570;&#x636E;">11. &#x5BA2;&#x6237;&#x7AEF;&#x5F02;&#x6B65;&#x52A0;&#x8F7D;&#x6570;&#x636E; <a href="#t811. &#x5BA2;&#x6237;&#x7AEF;&#x5F02;&#x6B65;&#x52A0;&#x8F7D;&#x6570;&#x636E;"> # </a></h2>
</li>
<li><a href="https://gitee.com/zhufengpeixun/zfssr/commit/cd2f5e55f2e5b259c7d6371404b3c72c40630f50">11. &#x5BA2;&#x6237;&#x7AEF;&#x5F02;&#x6B65;&#x52A0;&#x8F7D;&#x6570;&#x636E;</a><h2 id="t912. &#x670D;&#x52A1;&#x5668;&#x7AEF;&#x8DEF;&#x7531;">12. &#x670D;&#x52A1;&#x5668;&#x7AEF;&#x8DEF;&#x7531; <a href="#t912. &#x670D;&#x52A1;&#x5668;&#x7AEF;&#x8DEF;&#x7531;"> # </a></h2>
</li>
<li><a href="https://gitee.com/zhufengpeixun/zfssr/commit/c97ab24cd160231b102194dbe00dbd488eedfbe8">12. &#x670D;&#x52A1;&#x5668;&#x7AEF;&#x8DEF;&#x7531;</a><h2 id="t1013.&#x591A;&#x7EA7;&#x8DEF;&#x7531;">13.&#x591A;&#x7EA7;&#x8DEF;&#x7531; <a href="#t1013.&#x591A;&#x7EA7;&#x8DEF;&#x7531;"> # </a></h2>
</li>
<li><a href="https://gitee.com/zhufengpeixun/zfssr/commit/71ef659c1c725111017aaee6cdd77ba73eba156e">13.&#x591A;&#x7EA7;&#x8DEF;&#x7531;</a><h2 id="t1114.&#x540E;&#x53F0;&#x83B7;&#x53D6;&#x6570;&#x636E;">14.&#x540E;&#x53F0;&#x83B7;&#x53D6;&#x6570;&#x636E; <a href="#t1114.&#x540E;&#x53F0;&#x83B7;&#x53D6;&#x6570;&#x636E;"> # </a></h2>
</li>
<li><a href="https://gitee.com/zhufengpeixun/zfssr/commit/49e74bf937ed013abc3a33cf4a70530d83a0174e">14.&#x540E;&#x53F0;&#x83B7;&#x53D6;&#x6570;&#x636E;</a><h2 id="t1215. Node&#x4EE3;&#x7406;&#x670D;&#x52A1;&#x5668;">15. Node&#x4EE3;&#x7406;&#x670D;&#x52A1;&#x5668; <a href="#t1215. Node&#x4EE3;&#x7406;&#x670D;&#x52A1;&#x5668;"> # </a></h2>
</li>
<li><a href="https://gitee.com/zhufengpeixun/zfssr/commit/81f72d5dd6eea4b32f5a1cefad01eb116360b782">15. Node&#x4EE3;&#x7406;&#x670D;&#x52A1;&#x5668;</a><h2 id="t1316. &#x62BD;&#x53D6;App.js">16. &#x62BD;&#x53D6;App.js <a href="#t1316. &#x62BD;&#x53D6;App.js"> # </a></h2>
</li>
<li><a href="https://gitee.com/zhufengpeixun/zfssr/commit/38a4a38a3724943a088e2c60e4c6d54bb91dcffe">16. &#x62BD;&#x53D6;App.js</a><h2 id="t1417. &#x5B9E;&#x73B0;&#x5934;&#x90E8;&#x6839;&#x636E;&#x767B;&#x5F55;&#x72B6;&#x6001;&#x663E;&#x793A;&#x5BFC;&#x822A;">17. &#x5B9E;&#x73B0;&#x5934;&#x90E8;&#x6839;&#x636E;&#x767B;&#x5F55;&#x72B6;&#x6001;&#x663E;&#x793A;&#x5BFC;&#x822A; <a href="#t1417. &#x5B9E;&#x73B0;&#x5934;&#x90E8;&#x6839;&#x636E;&#x767B;&#x5F55;&#x72B6;&#x6001;&#x663E;&#x793A;&#x5BFC;&#x822A;"> # </a></h2>
</li>
<li><a href="https://gitee.com/zhufengpeixun/zfssr/commit/ae4855d4b8022284dfa6eada91316b17cd2d5296">17. &#x5B9E;&#x73B0;&#x5934;&#x90E8;&#x6839;&#x636E;&#x767B;&#x5F55;&#x72B6;&#x6001;&#x663E;&#x793A;&#x5BFC;&#x822A;</a><h2 id="t1518. &#x5B9E;&#x73B0;&#x767B;&#x5F55;&#x529F;&#x80FD;">18. &#x5B9E;&#x73B0;&#x767B;&#x5F55;&#x529F;&#x80FD; <a href="#t1518. &#x5B9E;&#x73B0;&#x767B;&#x5F55;&#x529F;&#x80FD;"> # </a></h2>
</li>
<li><a href="https://gitee.com/zhufengpeixun/zfssr/commit/1ffbec0e946ed195af358b6d2284645891ae7e34">18. &#x5B9E;&#x73B0;&#x767B;&#x5F55;&#x529F;&#x80FD;</a><h2 id="t1619. &#x9000;&#x51FA;&#x529F;&#x80FD;">19. &#x9000;&#x51FA;&#x529F;&#x80FD; <a href="#t1619. &#x9000;&#x51FA;&#x529F;&#x80FD;"> # </a></h2>
</li>
<li><a href="https://gitee.com/zhufengpeixun/zfssr/commit/1e8acc054ad6db4ce7f540ed06f1d0d358507cea">19. &#x9000;&#x51FA;&#x529F;&#x80FD;</a><h2 id="t1720. &#x52A0;&#x8F7D;&#x7528;&#x6237;&#x4FE1;&#x606F;">20. &#x52A0;&#x8F7D;&#x7528;&#x6237;&#x4FE1;&#x606F; <a href="#t1720. &#x52A0;&#x8F7D;&#x7528;&#x6237;&#x4FE1;&#x606F;"> # </a></h2>
</li>
<li><a href="https://gitee.com/zhufengpeixun/zfssr/commit/4ab0f61b0f0688bae4e66f97e6b34fb1f710cfce">20. &#x52A0;&#x8F7D;&#x7528;&#x6237;&#x4FE1;&#x606F;</a><h2 id="t1821. 404">21. 404 <a href="#t1821. 404"> # </a></h2>
</li>
<li><a href="https://gitee.com/zhufengpeixun/zfssr/commit/ea38ebf0a348ec6096dc52dffffe03cafa78355d">21. 404</a><h2 id="t1922. 301">22. 301 <a href="#t1922. 301"> # </a></h2>
</li>
<li><a href="https://gitee.com/zhufengpeixun/zfssr/commit/4a7c15b072d3e4d02b8017b19a1a72f0ea66ab1c">22. 301</a><h2 id="t2023. promise.all">23. promise.all <a href="#t2023. promise.all"> # </a></h2>
</li>
<li><a href="https://gitee.com/zhufengpeixun/zfssr/commit/5cce0eb28ad388329a8f9fd7af0fbf4b1a7aec98">23. promise.all</a><h2 id="t2124. &#x4F7F;&#x7528;CSS">24. &#x4F7F;&#x7528;CSS <a href="#t2124. &#x4F7F;&#x7528;CSS"> # </a></h2>
</li>
<li><a href="https://gitee.com/zhufengpeixun/zfssr/commit/a2d659ac816d951822e4d84866b86ada85707792">24. &#x4F7F;&#x7528;CSS</a><h2 id="t2226.withStyles">26.withStyles <a href="#t2226.withStyles"> # </a></h2>
</li>
<li><a href="https://gitee.com/zhufengpeixun/zfssr/commit/cb3473146cc84a671859ff47435934dcdfba6130">26.withStyles</a></li>
</ul>

        <div class="copyright">Powered by <a href="https://github.com/jaywcjlove/idoc" target="_blank">idoc</a>. Dependence <a href="https://nodejs.org">Node.js</a> run.</div>
    </div>
    
</div>

<script src="https://cdn.bootcss.com/jquery/3.0.0/jquery.js"></script>
<script>
$('.warpper .page-toc ul ul li a').on('click',function(){
  $('.warpper .page-toc ul ul li a').removeClass('my-active')
  $(this).addClass('my-active')
})
  // if (!$('.understand-me').length) {
  //   var bar = $(window).height() - $('.navbar ').height() - $('.page-toc').position().top;
  //   var count = bar / 26 / 2;
  //   var barHeight = $('.page-toc').outerHeight();
  //   $('.page-toc li').eq(0).children('a').addClass('red');
  //   var arr = [];
  //   $("h1,h2,h3,h4,h5,h6").each(function () {
  //     arr.push($(this).position().top);
  //   });
  //   var timer
  //   function dark() {
  //     clearTimeout(timer)
  //      timer = setTimeout(function () {
  //      var top = Math.abs($('.page-toc > ul').position().top);
  //      var cur = $('.content').scrollTop();
  //      for (var i = arr.length; i >= 0; i--) {
  //        if (arr[i] <= cur) {
  //          break;
  //        }
  //      }
  //      if (i === -1) {
  //        i = 0;
  //      }
  //      $('.page-toc li a').removeClass('red');
  //      $('.page-toc li').eq(i).children('a').addClass('red');
  //      let height = $('.page-toc li').eq(i).position().top-$('.page-toc').height(); // 如果当前的offset出去了 回到中间可好？
  //      $('.page-toc').scrollTop(height+$('.page-toc').height()/2);
  //    },200)
  //   }

  //   $('.content').on('scroll', dark);
  // }
</script>
<style>

    /* ::-webkit-scrollbar{width:14px;}
    ::-webkit-scrollbar-track{background-color:transparent;}
    ::-webkit-scrollbar-thumb{background-color:transparent;}
    ::-webkit-scrollbar-thumb:hover {background-color:transparent}
    ::-webkit-scrollbar-thumb:active {background-color:transparent} */

    .page-toc > ul .red {
        background: #f3f3f3;
        z-index: 1;
        border-left: 3px solid #009a61;
        -webkit-transition: all .2s ease;
        transition: all .2s ease;
        color: #000
    }





</style>
</body>
</html>
